Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

設定のログ表示のためのログ取得は別スレッドで行う #227

Merged
merged 1 commit into from
Oct 20, 2024

Conversation

mtgto
Copy link
Owner

@mtgto mtgto commented Oct 20, 2024

設定内のログ表示はOSLogStoreからの取得を行いますが、かなり時間がかかる処理なのでバックグラウンドで行いたいです。
ログ読み込みを行う関数にasyncをつけていたのですが、asyncをつけるだけではメインスレッドで実行されてしまいレインボーカーソルとなってしまっていました。

以前はこの修正がなくても問題なかったような気もしたのですが、Xcode 16からはSwiftUIのView全体が @mainActor がついているように修正されたようです。
https://qiita.com/temoki/items/582fc15697d71f931c8e

nonisolated修飾子をつけることで必ずメインスレッド外で実行されるようにします。

#210@uhooi さんの caf259c を参考にしています。

@mtgto mtgto merged commit 6e71c09 into main Oct 20, 2024
1 check passed
@mtgto mtgto deleted the background-log branch October 20, 2024 14:58
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant